110- 



ENTRY OF FILE NUMBER AND/OR OTHER 
IDENTIFICATION INFO, AND AMOUNT FOR 
CHECK, INTO REMOTE WORKSTATION 
AT LAW FIRM 



112-1 



114 



CHECK PRINTED ON WORKSTATION 
PRINTER, AND MAILED TO PATENT 
AND TRADEMARK OFFICE 



PTO RECEIVES 
CHECK AND CASHES 
AGAINST BANK ACCOUNT 



120 



CENTRAL OFFICE 
DEPOSITS MONEY 
IN ACCOUNT OR 
OTHERWISE INSURE 
ADEQUATE FUNDS 
PRESENT 



126 
—4 




INFORMATION REGARDING 
CHECKS PRINTED UPLOADED 
TO CENTRAL OFFICE 
BY REMOTE WORKSTATION 



122- 



ELECTRONIC INVOICE GENERATED ' 
AND TRANSMITTED TO LAW FIRM 
ACCOUNTING SYSTEM; PAPER 
INVOICE ALSO GENERATED 
BY WORKSTATION 



BANK SENDS TO 
CENTRAL OFFICE 

MONTHLY STATEMENT 
OF TRANSACTIONS 

TO CENTRAL OFFICE 




CENTRAL OFFICE RECONCILES 

MONTHLY STATEMENT WITH 
INFORMATION UPLOADED BY WS 



FIG. 1A 
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CENTRAL OFFICE 
SENDS BILL TO 
LAW FIRM FOR 
MONEY LOANED 
TO CLIENTS 



136 

-Jx 



BILL DUE 
IN 90 DAYS OR 
OTHER PERIOD 



146 



CENTRAL OFFICE 
RECEIVES CLIENT'S 
PAYMENT FROM 
LAW FIRM 



132 
_JL_ 



EXAMINE 
SITUATION AND 
CORRECT 
ERRORS 



© 



138 

_i 

SEND INVOICE 
TO CUENT (BY 
LAW FIRM) AT 
END OF MONTH 
OR OTHER PERIOD 



140 

\ ' 




INVOICE DUE 
IN 30 DAYS OR 
OTHER PERIOD 


142 




LAW FIRM RECEIVES 
MONEY FROM 
CLIENT 


144 




LAW FIRM SENDS 

PAYMENT TO 
CENTRAL OFFICE 



FIG. 1B 



210« 



ENTRY OF FILE NUMBER AND/OR OTHER 
IDENTIFICATION INFO. AND REQUESTED 
AMOUNT INTO REMOTE WORKSTATION 



212. 



213. 



T 



WORKSTATION ISSUES AUTHORIZATION 
CODE FOR DEBIT OF REQUESTED 
AMOUNT FROM DEPOSIT ACCOUNT 



214 

i_ 



I 



TRANSMITTAL INCLUDING AUTHORIZATION 
CODE SENT TO EPO/PCT 
(DEPOSIT ACCOUNT AUTHORIZATION) 



EPO/PCT RECEIVES 

transmittal and debits 
oeposit account 



220 
1 



CENTRAL OFFICE 
DEPOSITS MONEY 
IN ACCOUNT OR 
OTHERWISE INSURE 
ADEQUATE FUNDS 
PRESENT 



226 
_S 




INFORMATION REGARDING 
AUTHORIZATION UPLOADED 
TO CENTRAL OFFICE BY WS 



218- 



ELECTRONIC INVOICE GENERATED 
AND TRANSMITTED TO LAW FIRM 
ACCOUNTING SYSTEM; PAPER 
INVOICE ALSO GENERATED 
BY WORKSTATION 



CENTRAL OFFICE RECEIVES 
MONTHLY STATEMENT OF 
ACCOUNT DEBITS 
IDENTIFIED BY 
AUTHORIZATION COOE 




CENTRAL OFFICE RECONCILES 

MONTHLY STATEMENT WITH 
INFORMATION UPLOADED BY WS 



FIG. 2A 
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CENTRAL OFFICE 
SENDS BILL TO 
LAW FIRM FOR 
MONEY LOANED 
TO CLIENTS 



232 
V 



EXAMINE 
SITUATION AND 
CORRECT 
ERRORS 



236 
* 




BILL 


DUE 


IN 90 DAYS OR 


OTHER PERIOD 



246 



CENTRAL OFFICE 
RECEIVES CLIENT'S 
PAYMENT FROM 
. LAW FIRM 



FIG. 2B 



® 



238 
_i 



SEND INVOICE 
TO CLIENT (BY 
LAW FIRM) AT 
END OF MONTH 
OR OTHER PERIOD 



240 
_s 



INVOICE DUE 
IN 30 DAYS OR 
OTHER PERIOD 



242 



LAW FIRM RECEIVES 
MONEY FROM 
CLIENT 



244 



LAW FIRM SENDS 

PAYMENT TO 
CENTRAL OFFICE 



i 



ENTRY OF FILE NUMBER AND/OR OTHER 
310 J IDENTIFICATION INFO. AND AMOUNT FOR 
CHECK, INTO REMOTE WORKSTATION 
AT LAW FIRM 



TO STEP 
120 OR 220 



TO STEP 
144 OR 214 



313-T 



WORKSTATION ELECTRONICALLY 
311 J CONTACTS CENTRAL OFFICE FOR 
CONFIRMATION/APPROVAL 



WORKSTATION ISSUES CHECK 
OR AUTHORIZATION CODE 



CODE OR CHECK SENT 
TO PATENT AGENCY 




TO STEP 
122 OR 222 
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410 



LAW FIRM 



418 
-J 



ACCOUNTING/ 
BILLING 
SYSTEM 



^422 



CHECK 
PRINTING/ 
AUTH. COOE 
SYSTEM 



? 

416 



434 



420 



412 
— i 



PATENT 
AND 
TRAOEMARK 

PAYMENT 
FEE SYSTEM 



432. 



424 



426 



PATENT 
AGENCY 



428 



414 
_S 



430 



ACCOUNT 



PATENT AGENCY 
OR FINANCIAL 
INSTITUTION 
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July 22, 1997 Payee: U.S. Potent k Trademark Office 

Fee Code: 101/201 Basic filing Fee-Utility 
Client Number. 00997 
Matter Number: xxxx 

Note: This requires special attention. 






July 22. 1997 

Two Thousand AND 0/100 DOLLARS 
U.S. Potent k Trademark Office 


$ 2.000.0 




FIG. 18 


PTO Management Company Invoice 

Invoice Dote: July 22. 1997 






Item: 

Check Number: 151 1 
From Account: 

58-67-9785 - PTFM Checks for U.S. PTO 
Request by: 

Brian Lorson on: 07/22/1997 12:53:16 
Client Number 00997 Matter Number xxxx 
Note: This requires special attention. 






Check Amount: 
Fee: 


' $ 2,000.0 
$ \ 18.75 




Total Due By 09/20/1997: | 


$ 2.118.75 




Discounted Total Due If Paid By 08/11/1997: 
Discounted Total Due If Paid By 08/11/1997: 


$ 2.029.69 
$ 2,059.38- 




FIG. 19 



Deposit Account Authorization 


PTFM EPO Deposit Account 


Account Number XYZ234784 


Authorization Number. SIWK0OQ21Q23 




Dote Fee Code 


Check Amount 


July 22. 1997 sdMsfd 


$ 300.0 


Payee: European Patent Office 




Requested by: Brian Larson 


on: 07/22/1997 12:44:18 


Cfient Number 00999 




Matter Number: sfgs 


Fee Assessed: t 6.75 



FIG. 20 



PTO Management Company Invoice 

Invoice Date: July 22, 1997 


Item: 

Authorization Number: SLWK00021023 
From Account: 

XYZ234784 - PTFM EPO Deposit Account 
Request by: 

Brian Larson on: 07/22/1997 12:53:16 
Client Number. 00999 Matter Number xm 




Authorization Amount: 


$ 300.0 


Fee- 


$ 6.75 


Total Due By 08/21/1997: 


$ 306.75 





FIG. 21 
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Database: PTFM 



Structure 


for table: 


C : \PMCSOURCE\ACCOUNT . DBF 


Number of 


data records: 


9 




Date of last update: 


07/15/1997 




Code Page : 


1252 




Field 


Field Name 


Type 






Width 


Dec Index Collate 


Nulls 


1 


AC CODE 


Character 






8 


Asc Machine 


No 


2 


AC NAME 


Character 






30 


Asc Machine 


No 


3 


AC CLIENTNUM. . 


Character 






10 




No 


4 


AC CLIENTNAM. . 


Character 






50 




No 


5 


AC ACCOUNTNU. . 


Character 






20 




No 


6 


AC ACCOUNTTY . . 


Character 






18 




No 


7 


AC BALANCE 


Numeric 






12 


2 


No 


8 


AC NEXTCHECK 


Numeric 






~ 10 




No 


** Total ** 








159 






Structure 


for table: 


C : \PMCSOURCE\ACCTTYPE . DBF 


Number of 


data records : 


9 





Date of last update: 
Memo file block size: 
Code Page: 

Field Field Name 



1 
2 
3 
4 
5 
6 



Width 
AT_TYPE 
18 

AT_KEEPBALAN. 
1 

ATJTRANSTYPE . 
4 

AT_PAYEES 
4 

AT_CANEXCEED 
1 

AT_CHARGEFEE 
1 



06/10/1997 
64 

1252 

Type 

Dec Index Collate 

Character 

Logical 

Memo 

Memo 

Logical 

Logical 



Nulls 
No 
No 
No 
No 
No 
No 



FIG. 24A 



7 


AT CHECKONLY 
1 


Logical 


No 


8 


AT AUTHOR I ZA . . 
1 


Logical 


No 


9 


AT USPTOCODE 
1 


Logical 


No 


10 


AT EPOCODE 
1 


Logical 


No 


11 


AT EXPORTTOP. . 
1 


Logical 


NO 



** Total ** 



Structure for table : 
Number of data records: 
Date of last update: 
Code Page: 



C : \PMCSOURCE\CLIENT . DBF 



Field 



** Total ** 



Field Name 

Width 
CL_CLI ENTNUM . 

10 
CL_NAME 

50 
CL_PLAN 

20 

81 



Structure for table: 
Number of data records : 
Date of last update : 
Memo file block size: 
Code Page: 

Field Field Name 
Width 

1 DE_CODE 

8 

2 DE_CL I ENTNUM. 

20 

3 DE_MATTERNUM . 

20 

4 DE_DATET I ME 

8 

5 DEJTRANSACTI . 

3 



06/20/1997 
1252 

Type 

Dec Index Collate 

Character 

Character 

Character 



Nulls 
No 
No 
No 



C : \PMCSOURCE\DETAIL . DBF 

69 

07/15/1997 
64 

1252 

Type 

Dec Index Collate 

Character 



Character 
Character 
DateTime 
Character 



Nulls 
No 
No 
No 
No 
No 
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6 DE_ 

7 DE_ 

8 DE_ 

9 DE_ 

10 DE_ 

11 DE_ 

12 DE_ 

13 DE_ 
14' DE_ 

15 DE_ 

16 DE_ 

17 DE_ 

18 DE_ 

19 DE_ 

20 DE_ 

21 . DE_ 

22 DE_ 

23 DE_ 
** Total ** 



PAYEE 
50 

PTOCODE 

75 
AMOUNT 
10 

PLUSMINUS 
2 

WHO 
" 25 

LOCATION 
10 

CHECKNUMB. 

10 
NOTES 
4 

FEE1 
8 

DATEDUE1 
8 

FEE2 
8 

DATEDUE2 
8 

FEE3 
8 

DATEDUE3 
8 

_STATUS 
17 

SELECTED 
1 

PRINTDATE . 
8 

_EXPORTDAT . 
8 

328 



Character 

Character 

Numeric 

Numeric 

Character 

Character 

Numeric 

Memo 

Numeric 

Date 

Numeric 

Date 

Numeric 

Date 

Character 
Logical 
DateTime 
DateTime 



No 
No 
No 
No 
No 
No 
No 
No 
No 
No 
No 
No 
No 
No 
No 
No 
No 
No 



Structure for table: 
Number of data records: 
Date of last update: 
Code Page: 

Field Field Name 
Width 



C : \PMCSOURCE\PTOCODE . DBF 

149 

05/16/1997 
1252 

Type 

Dec Index Collate Nulls 
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i 

2 

** Total ** 



PT_CODE 
75 

PTJJSPTOCODE 
1 

77 



Character 
Logical 



No 
NO 



Structure for table: 
Number of data records: 
Date of last update : 
Code Page: 



C : \PMCSOURCE\RATE . DBF 

48 

06/27/1997 
1252 



Field 


Field Name 




Type 






Width 


Dec 


Index Collate 


Nulls 


1 


RA PLAN 
20 




Character 


No 


2 


RA LOWERLIMI . . 




Numeric 






8 


2 




No 


3 


RA UPPERLIMI . . 




Numeric 






8 


2 




No 


4 


RA DAYSDUE 1 
3 




Numeric 


No 


5 


RA AMOUNT 1 




Numeric 






8 


2 




No 


6 


RA DAYSDUE 2 
3 




Numeric 


No 


7 


RA AM0UNT2 




Numeric 






8 


2 




No 


8 


RA DAYSDUE 3 
3 




Numeric 


No 


9 


RA AM0UNT3 




Numeric 






8 


2 




No 


10 


RA NOTALLOWE . . 
1 




Logical 


No 



** Total ** 



71 



Structure for table: 
Number of data records : 
Date of last update: 
Memo file block size: 
Code Page: 

Field Field Name 
Width 
1 SU_ITEM 
20 



C : \ PMCSOURCE \ SETUP . DBF 

10 

07/22/1997 
64 

1252 

Type 

Dec Index Collate Nulls 

Character 

No 



FIG. 24D 



2 SU_NUMBER Numeric 

10 2 No 

3 SU__DATA Memo 

4 No 



** Total ** 

35 



Structure for table: 
Number of data records: 
Date of last update: 
Code Page: 



C : \ PMC SOURCE \TRANTYPE . DBF 



06/10/1997 
1252 



Field 


Field Name 




Type 






Width 


Dec 


Index Collate 


Nulls 


1 


TR TRANSACT I . 
3 




Character 


No 


2 


TR DESCRIPTI. 
20 




Character 


No 


3 


TR PLUSMINUS 
2 




Numeric 


No 


4 


TR CHKACCTVA . . 
1 




Logical 


No 


5 


TR AUTACCTVA. . 
1 




Logical 


No 


6 


TR CHKLIMITE. . 
1 




Logical 


No 


7 


TR AUTLIMITE . . 
1 




Logical 


No 


8 


TR CHARGEFEE 
1 




Logical 


NO 



** Total ** 



31 



Structure for table: . 
Number of data records: 
Date of last update: 
Code Page: 

Field Field Name 
Width 

1 US_ID 

20 

2 US_LAST 

15 

3 US_FIRST 

15 

4 US_PASSWORD 

15 



C : \PMCSOURCE\USER . DBF 



05/02/1997 
1252 

Type 

Dec Index Collate 

Character 

Character 

Character 

Character 



Nulls 
No 
No 
No 
No 
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5 


US CHECKBALiA 

1 




No 


6 


US_VIEWREQUE . . 
1 


Logical 


No 


7 


US CREATEREQ . . 
1 


Logical 


No 


8 


US_CANCELREQ . . 
1 


Logical 


No 


9 


US MODI FYACC . . 
1 


Logical 


No 


10 


US PRINTREPO . . 
1 


Logical 


No 


11 


US EXTRACTDA . . 


Logical 





1 No 
** Total ** 



Program File: MAIN.PRG 

JSCREEN. Width =633 
_SCREEN. Height =418 
_SCREEN.Icon = "opening . ico" 

SET CENTURY ON 

SET BELL OFF 

SET CONFIRM ON 

SET DELETED ON 

SET MULTILOCKS ON 

SET PROCEDURE TO MAIN.PRG 

OPEN DATABASE PTFM 

PUBLIC frmMenu, gcLoginID, gcFullName, gcLocation, gcProgName 

USE Setup 

SET ORDER TO . I tern 

IF SEEK { " PROGNAME " ) 

gcProgName = TRIM (Setup. SU_Data) 

^SCREEN. Caption = gcProgName 

ELSE 

gcProgName = "Patent & Trademark Fee Management" 

END IF 

IF SEEK ( " LOGINID" ) 

gcLoginID - TRIM (Setup . SU_Dat a) 

ELSE 

gcLoginID = "Unknown" 



PIG. 24P 



END IF 



IF SEEK ( " FULLNAME" ) 

gcFullName = TRIM (Setup . SUJDat a) 

ELSE 

gcFullName = "Unknown" 

END IF 

IF SEEK ( "LOCATION" ) 

gcLocation = TRIM (Setup . SU_Data) 

ELSE 

gcLocation = "Unknown" 

ENDIF 

CLOSE TABLES ALL 

DO FORM Menu NAME f rmMenu 

READ EVENTS 

************************************* 

FUNCTION GetDueDate 

* Finds the Monday which is the specified number of weeks after 

* the date the request was made. If the request was made on a 

* Monday, do not count that Monday. 
LPARAMETERS ldDate, InNumMondays 

Local InMondayCnt 

InMondayCnt = 0 

DO WHILE InMondayCnt < InNumMondays 
ldDate = ldDate +1 
IF DOW (ldDate, 2) = 1 

InMondayCnt = InMondayCnt + 1 

ENDIF 

END DO 

RETURN ldDate 

************************************* 
FUNCTION TextDollar 

PARAMETERS nNumber 

LOCAL InDollars, InCents 

InDollars = INT (nNumber) 

InCents = (nNumber - InDollars) * 100 
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RETURN TextNumeric (InDollars) + n AND "+STR (InCents, 2) +"/100 
DOLLARS " 

******★★*★***★*****■*********★**#***** 

FUNCTION TextNumeric 

PARAMETERS nNumber 

LOCAL lcString, lnWorkNumber 

InWorkNumber = nNumber 
lcString » 

IF InWorkNumber >= 1000000 

lcString = TextNumeric (InWorkNumber/ 10 000 00) + "Million " 

InWorkNumber = InWorkNumber - 
(INTQnWorkNumber/1000000) *1000000) 
END IF 

IF InWorkNumber >= 1000 

lcString = lcString + TextNumeric (InWorkNumber/ 1000) + 
"Thousand " 

InWorkNumber = InWorkNumber - (INT ( InWorkNumber/ 1 000) * 1000) 

ENDIF 
DO CASE 

CASE InWorkNumber >= 900 

lcString = lcString + "Nine Hundred " 

InWorkNumber = InWorkNumber - 900 
CASE InWorkNumber >= 800 

lcString = lcString + "Eight Hundred n 

InWorkNumber = InWorkNumber - 800 
CASE InWorkNumber >= 700 

lcString = lcString + "Seven Hundred " 

InWorkNumber = InWorkNumber - 700 
CASE InWorkNumber >= 600 

lcString = lcString + "Six Hundred " 

InWorkNumber = InWorkNumber - 600 
CASE InWorkNumber >= 500 

lcString = lcString + "Five Hundred " 

InWorkNumber = InWorkNumber - 500 
CASE InWorkNumber >= 4 00 

lcString = lcString + "Four Hundred " 

InWorkNumber = InWorkNumber - 400 
CASE InWorkNumber 300 

lcString = lcString + "Three Hundred " 

InWorkNumber = InWorkNumber - 300 
CASE InWorkNumber >= 200 
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lcString = lcString + "Two Hundred 
InWorkNumber = InWorkNumber - 200 

CASE InWorkNumber >= 100 

lcString = lcString + "One Hundred 
InWorkNumber = InWorkNumber - 100 

ENDCASE 

DO CASE 

CASE InWorkNumber >= 90 

lcString = lcString + "Ninety " 
InWorkNumber = InWorkNumber - 90 

CASE InWorkNumber >= 80 

lcString = lcString + "Eighty n 
InWorkNumber = InWorkNumber - 80 

CASE InWorkNumber >= 70 

lcString = lcString + "Seventy " 
InWorkNumber = InWorkNumber - 70 

CASE InWorkNumber >= 60 

lcString = lcString + "Sixty n 
InWorkNumber « InWorkNumber - 60 

CASE InWorkNumber >= 50 

lcString = lcString + "Fifty " 
InWorkNumber = InWorkNumber - 50 

CASE InWorkNumber >= 40 

lcString = lcString + "Forty " 
InWorkNumber = InWorkNumber - 40 

CASE InWorkNumber >= 30 

lcString = lcString + "Thirty " 
InWorkNumber = InWorkNumber - 30 

CASE InWorkNumber >= 20 

lcString = lcString + "Twenty " 
InWorkNumber = InWorkNumber - 2 0 

CASE InWorkNumber >= 19 

lcString « lcString + "Nineteen " 
InWorkNumber = InWorkNumber - 19 

CASE InWorkNumber >= 18 

lcString = lcString + "Eighteen " 
InWorkNumber = InWorkNumber - 18 

CASE InWorkNumber >= 17 

lcString = lcString + "Seventeen " 
InWorkNumber = InWorkNumber ▼ 17 

CASE InWorkNumber >= 16 

lcString ■ lcString + "Sixteen " 
InWorkNumber = InWorkNumber - 16 

CASE InWorkNumber >= 15 

lcString = lcString + "Fifteen " 
InWorkNumber = InWorkNumber - 15 
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CASE InWorkNumber >= 14 

IcString - lcString + "Fourteen " 
InWorkNumber = InWorkNumber - 14 

CASE InWorkNumber >= 13 

lcString = lcString + "Thirteen " 
InWorkNumber = InWorkNumber - 13 

CASE InWorkNumber >= 12 

lcString lcString + "Twelve " 
InWorkNumber = InWorkNumber - 12 

CASE InWorkNumber >= 11 

lcString = lcString + "Eleven 0 
InWorkNumber = InWorkNumber - 11 

CASE InWorkNumber >= 10 

lcString = lcString + "Ten " 
InWorkNumber = InWorkNumber - 10 

END CASE 

DO CASE 

CASE InWorkNumber >= 9 

lcString » lcString + "Nine w 
InWorkNumber = InWorkNumber - 9 

CASE InWorkNumber >= 8 

lcString = lcString + "Eight " 
InWorkNumber = InWorkNumber - 8 

CASE InWorkNumber >= 7 

lcString = lcString + "Seven " 
InWorkNumber = InWorkNumber - 7 

CASE InWorkNumber 6 

lcString = lcString + "Six " 
InWorkNumber = InWorkNumber - 6 

CASE InWorkNumber >= 5 

lcString = lcString + "Five " 
InWorkNumber = InWorkNumber - 5 

CASE InWorkNumber >= 4 

lcString = IcString + "Four " 
InWorkNumber = InWorkNumber - 4 

CASE InWorkNumber >= 3 

lcString = lcString + "Three " 
InWorkNumber = InWorkNumber - 3 

CASE InWorkNumber >= 2 

lcString = lcString + "Two " 
InWorkNumber = InWorkNumber - 2 

CASE InWorkNumber >= 1 

IcString = lcString + "One " 
InWorkNumber = InWorkNumber - 1 

ENDCASE 
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IF EMPTY (lcSt ring) 
lcString = "No 

END IF 

RETURN lcString 
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